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OVERFLOW DETECTION AND CLAMPING WITH PARALLEL 
OPERAND PROCESSING FOR FIXED-POINT MULTIPLIERS 

BACKGROUND OF THE INVENTION 

5 The present invention relates generally to the multiplication and clamping prediction 

of fixed-point multipliers. More particularly, the invention relates to a method and apparatus 
for increasing the speed of fixed-point data paths that involve multiplication of operands and 
parallel overflow detection and clamping based upon the magnitude of those operands- 
Electrical circuits are routinely employed to perform arithmetic operations of operands 

10 represented by logical representations. Generally, it is desirable for arithmetic circuitry, and 
in particular multiplication circuitry, to have the fewest number of bits in order to perform the 
required calculations. Minimization of the required number of bits facilitates speed of the 
calculating circuit. However, counter-balancing the desire to have a limited number of bits to 
perform a given calculation is to avoid answer overflow. Overflow, or the situation in which 

15 an answer will exceed the number of bits designed for the answer, is not acceptable, as 
valuable valid data may be lost in performing the calculations. In circuits that perform 
calculations with a number of bits that may yield answers that overflow the set number of bits, 
clamping can be used to ensure that a result that overflows is clamped to a given acceptable 
value. Normally, the largest magnitude positive or negative representable number is 

20 employed as the overflow value. While the employment of a clamping operation is not 

always desirable, it is generally considered to be better than an overflow which may cause 
wrapping or undesired bits stored in the particular multiplication circuitry. 

Typically, when clamping is desired, it is performed in a sequential fashion. In other 
words, the arithmetic operation is performed first, and when the result is available, it is then 

25 analyzed for overflow. If clamping is required, a clamping value replaces the computed 
value. 

Referring now to Fig. 1 , a prior system illustrates the serial processing in which the 
clamping analysis follows multiplication of particular operands. In this instance, operand 1 
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(reference numeral 2) and operand 2 (reference numeral 4) are input into an arithmetic 
operator 6. The output 8 from the aiithmetic operator 6 is then directed into the overflow 
detection scheme 10. Any delays between arithmetic operator 6 and the overflow 
detection 10 are compounded, with each of their respective delays adding to the overall circuit 
5 delay. The clamp value 12 as determined by the overflow detection 10 is input along with the 
result 14 of the arithmetic operation 6, and a preset clamp value 16 into multiplexer 18. 
Multiplexer 18 selects the operation result 14 or the preset clamp value 16 in the instance of 
overflow detection based upon the logical level of clamp bit 12. The result is then output into 
register 20. 

10 A major problem with sequential operation is that any delays, for both the arithmetic 

operation and the overflow analysis, tend to compound and therefore yield a relatively slow 
circuit to the extent that all delays are combined and added together to determine the total 
circuit delay. In any arithmetic operation, multiplication delays tend to be the largest. 
Therefore, there exists a need to implement a circuit and method in which arithmetic 

1 5 operations such as multiplication may be performed along with overflow detection. The 

result is a circuit that eliminates the compounded delay made up of the accumulation of each 
individual delay associated with sequential overflow analysis and operand processing. 

SUMMARY OF THE INVENTION 

20 The present invention provides overflow detection and clamping in parallel with 

multiplication of fixed-point multiplier operands that overcome the aforementioned problems, 
and provides a faster circuit than would otherwise be available from serial clamping analysis 
and arithmetic operation. 

In accordance with one aspect of the invention, a method of detecting overflow in a 

25 clamping circuit includes inputting a first operand having a fixed-point format (i.e. 

represented by a fixed number of bits) into the clamping circuit and inputting a second 
operand having a second fixed-point format into the clamping circuit. A product overflow 
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output is determined based upon the first and second fixed-point format. The method includes 
predicting whether multiplication of the first operand with the second operand yields a result 
that exceeds the product overflow output, and performing at least partially the multiplication 
of the first and second operands. The determining step occurs substantially in parallel with 

5 the performing step. 

In accordance with another aspect of the invention, a method of clamp detection is 
disclosed, and includes inputting a first and second operand to both a multiplier and an 
overflow detection circuit. The method includes multiplying the first and second operands to 
generate a result not to exceed a pre-determined number of bits, and determining an initial 

10 clamping predictor bit based upon the first operand and the second operand. The initial 

clamping predictor bit is logically ORed with a most significant bit of the result to produce a 

final clamping predictor bit. 

Again, the multiplying and determining steps occur substantially in parallel. 

In yet another aspect of the invention, a multiplication overflow detection circuit is 
1 5 disclosed. The circuit includes multiplication circuitry for at least partially multiplying a first 
and a second operand, overflow detection circuitry receiving the first and second operands 
that detects whether a result of the multiplication of the first and second operands exceed a 
maximum representable positive or negative value. The multiplication circuitry and the 
overflow detection circuitry operate substantially in parallel. 

20 

BRIEF DESCRIPTION OF THE DRAWINGS 

The drawings illustrate the best mode presently contemplated for carrying out the 

invention. 

In the drawings: 

25 Fig. 1 is a schematic of a prior detection overflow scheme showing serial operand 

operation and overflow detection. 
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Fig. 2 is a schematic of parallel operation of the arithmetic operator and the overflow 
detection in accordance with the present invention. 

Fig. 3 is a table illustrating necessary information in determining whether to clamp 
multiplication of the two operands in accordance with one aspect of the present invention. 

Fig. 4 is a graph illustrating the simple overflow predictor and the regions necessary 
for additional overflow prediction calculations. 

Fig. 5 shows a schematic of another aspect of the present invention. 

DETAILED DESCRIPTION OF THE PREFE RRED EMBODIMENT 

Referring now to Fig. 2, a clamping system 22 in accordance with the present 
invention is illustrated. Operand 1 is loaded into register 24 and operand 2 is similarly loaded 
into register 26. Registers 24, 26 are preferably flip-flops, but any suitable register capable of 
storing the operands are contemplated. Also, the operands may be passed directly from other 
arithmetic operators or other related logic, if suitable for the application. Operand 1 and 
operand 2 are loaded in a fixed-point format. 

In fixed-point arithmetic, numbers are represented by zero or one sign bit, zero or 
more integer bits, and zero or more fractional bits. The integer and fractional bits can be a 
magnitude, a 1 's complement, or a 2's complement value. The most common case is the 2's 
complement case. A short-hand description is used to denote how many bits there are in each 
category. This description is typically: <sign-bits>.<integer-bits>.<fractional-bits> ors.i./ 
For a signed number with 4 integer bits and 5 fractional bits the notation would be 1 .4.5. For 
an unsigned number with 6 integer bits and 3 fractional bits the notation would be 0.6.3, and 
often the leading zero is omitted to yield 6.3. 

For a given fixed-point representation s.Lf there are associated numerical properties, 
(and assuming that the 2's complement is used): 

Largest positive number representable: 2' - 2~ f 
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Largest (magnitude) negative number representable: -2i 

Smallest positive number representable: 2" 

Smallest (magnitude) negative number representable: -2" 

When fixed-point numbers are used in arithmetic operations such as additions, 

subtractions, and multiplications, the results generally require more bits to avoid overflow. 

The rules for the two types of operations are: 

1 . Addition and subtraction: 

• If both inputs are of the same format s.lf then the output requires s. (i+l).f 
to avoid overflow. 

• If the inputs are of different formats sAl.fl and sA2.f2, then choose 

i = max(il ,i2) and f = max(fl ,f2). Then the output requires s.(i+l).f bits to 
avoid overflow. 

2. Multiplication: 

• If the inputs are of the same format s.r/then the output requires 
s.(2*i+l).(2*j) to avoid overflow. 

• If the inputs are of different formats sAl.fl and sJ2.f2, then the output 
requires s.(il+i2+l).(fl+f2) to avoid overflow. 

Since multiplication most often produces the need for overflow detection and 
clamping, it is preferred that the present invention be utilized in multiplication of operand 1 
and operand 2, with each operand in a fixed-point format. As Fig. 2 demonstrates, operand 1 
and operand 2 are both supplied to the overflow detection 28 as well as the arithmetic 
operator or multiplier 30. The multiplier 30 takes operand 1 and operand 2 and determines at 
least a partial product of the binary operands. It is important to note that the multiplier does 
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not have to be fall precision. It need only be twice the precision that is desired to be 
represented in the final result. For example, if it is desired to multiply two operands, each 
having eight bits, when the multiplication of eight bits and eight bits occurs, the answer will 
have sixteen bits of output. However, if it is only desired to have eight bits to come out in the 
5 final output, when the multiplication could actually generate up to sixteen bits, the multiplier 
will be used to generate nine bits. The nine bits represent twice the desired output range. 
Therefore, in the above-identified example, the answer will have a nine-bit result instead of 
the full sixteen-bit result. The final seven bits of the multiplication are not necessarily 
calculated. 

10 Operand 1 and operand 2 are also presented to the overflow detection logic. The 

overflow detection 28 occurs in parallel with the multiplier 30 operation. It is the 
substantially simultaneous processing of the overflow detection and the multiplication that 
produces the efficiencies in processing time for the circuit. Also, it is the fact that the full 
product need not necessarily be calculated that results in further efficiencies in processing 

15 time. 

The overflow detection circuit 28 considers the two input operands and predicts 
whether or not they will cause the product to overflow. The overflow prediction circuit 28 
predicts when the product is going to be greater than or equal to two times the maximum 
desired value. This handles most of the clamping cases, but it is not exact. To get exact 
20 clamping, the product is computed to the (io-f-l)'th integer bit, and the most significant bit of 
the product 37 is used to finally determine whether or not to clamp. 

The fixed-point format of the two inputs and the desired output must be known. These 
formats are denoted as: 

25 Operandi: sALfl 

Operand2: sA2J2 
Output: sJo.fo 
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The product of the two input operands will require s.(il+i2+l).(fl+f2) to avoid 
overflow. The assumption is that io < il+i2+l y (because, if io > H+i2+l then an overflow 
can not occur). 

Example 

Consider the simple case of two positive input operands that yield a positive product. 
The maximum positive number that can be represented by the desired output representation is: 

2 io_ 2 -fo 

Therefore, any combination of input operands that yields a product greater than or 
equal to the maximum value should be clamped to the maximum positive value: 

Output = opl * op2 if (opl * op2) < 2 io - 2' f0 
Output - 2 i0 - T f0 if (opl * op2) > 2 io - T f0 

The result 32 of multiplier 30 (which will in a preferred embodiment be a partial 
multiplication) is output from the multiplier 30. The detection overflow 28 outputs result 34 
from its overflow detection circuitry, and as a result of a logical level of the clamp bit 34 it is 
determined whether clamping will occur. The most significant bit 37 (on line 36) of result 32 
is logically ORed with clamp bit 34 through OR gate 38. Therefore, if any of clamp bit 34 or 
the most significant bit 37 is logically high, clamping will occur and a clamping signal 40 is 
output from OR gate 38. The clamping signal 40 is input into multiplexer 42. Result 32 of 
the multiplication is also input into multiplexer 42. Clamp value 44 is preferably hard-wired 
into multiplexer 42. The value of clamp value 44 is predetermined depending on the number 
of bits in operand 1 and operand 2. Preferably, the clamp value is the maximum representable 
positive or negative value. It is contemplated that in selecting a positive or negative value for 
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operand 1 or operand 2, the MSB (most significant bit) of each register 24, 26 could be 
exclusively ORed (XOR) together such that if the operands are of a different sign, the 
negative clamping value will be used for clamp value 44. Consequently, if both operands are 
of the same sign, the positive value for clamp value 44 will be used. Multiplexer 42 will 
select either result 32 or clamp value 44 depending upon the logical level of clamp signal 40, 
and will output the selection into output register 46. 

Referring now to Fig. 3, a binary representation of several scenarios are given. 

Take the case of two 1 .6.4 operands, multiply them and return the product clamped to 
a 1 .6.4 number. The maximum representable value in the output is 2 6 - T 4 - 64 -1/1 6 = 
63.9375. Some simple cases exist: 

If opl > 32 and op2 > 2 then clamp (45a) 

If opl >\ 6 and op2 > 4 then clamp (45b) 

If opl > 8 and op2 > 8 then clamp (45c) 

If opl > 4 and op2 > 1 6 then clamp (45d) 

If opl > 2 and op2 > 32 then clamp (45e) 

The binary representation of these scenarios is given in Fig. 3. 

It can be seen that the number of leading zeros in the integer portion of the operands is 
indicative of the magnitude of the operands, and by adding the number of leading zeros of 
both opl (47) and op2 (49), there is a constant number of leading zeros 5 1 . Therefore, the 
fixed-point format of the operands will determine the constant number of leading zeros to 
determine whether clamping occurs. Clamping must occur when: 

If (<opl leading zeros> + <op2 leading zeros>) < 4 then clamp 
Else don't clamp 
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This relatively simple predictor works for a substantial portion of products, but it is 
not completely accurate. If only this predictor were used, it would be possible to get products 
that could be as much as twice the desired max value, i.e., 

(max product given simple predictor) <2 * (desired max value) 

Therefore, to get an accurate clamp predictor, the above simple predictor is used, and 
the multiplication generates a result that is of format s.(io+l).fo. Then, for positive operands, 
an overflow is detected by ORing together the MSB of the integer bits and the clamp- 
prediction. 

Referring now to Fig. 4, a graph is shown showing the regions of products that are 
clamped by the initial clamp predictor. The broad region covered by the simple, initial clamp 
predictor is shown generally by the numeral 50. Regions 52 represent those products that 
require the io+1 integer bits of the product to get accurate overflow detection and therefore 
require more precise clamp prediction. Region 51 represents the region where clamping is not 
needed because the product does not exceed the desired number of bits. However, this graph 
is representative of only one particular set of operands (both positive). Other predictors will 
produce different data depending upon the signs of the operands. 

General Case 

The general case consists of three subcases depending on the signs of the input 
operands: 

Case 1 : (opl > 0 and op2 > 0) 
Case 2: (opl < 1 and op2 < 1) 

Case 3: (opl > 0 and op2 < 1) or (opl < 0 and op2 > 0) 

Each of these cases will be examined in turn. 

Case 1: Both operands are positive 
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The simple clamp predictor is: 

If the sum of the input operands' leading zeros is less than or equal to 
5 (il -io) + (i2-io) + (io-2) 

= iI + i2-io-2 

then the circuit must clamp. 

10 The accurate clamp prediction must use the (io + 1) bit of the product, i.e., the product 

must be computed at least to (io + 1) integer bits. This bit is ORed logically with the simple 

clamp predictor to yield the accurate clamp determination. 



Case 2: Both operands are negative 

15 

When both operands are negative, their product is positive. Therefore, if an overflow 
case exists we clamp to the same value as mentioned before, namely: 



20 



25 



2 io_ 2 -fo 



When both operands are negative the simple clamp predictor must count leading ones 

in the input operands. If the sum of the input operands' leading ones is less than or equal to 

(il - io) + (i2 - io) + (io - 1) 
= il+i2-io-l 

then the circuit must clamp. 



However, there is an additional case, when both operands have only zeros after the 
leading ones (e.g., 1 1 1 100.0000) then the simple clamp predictor should also clamp. This is 
30 like counting leading zeros on a bit-reversed version of each input. If the trailing zeros plus 
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the leading ones equal (i+f) for both Inputs then clamp. As before, the accurate clamp 
prediction must use the (io + 1) bit of the product, i.e., the product must be computed at least 
to (io +1) integer bits. This bit is ORed logically with the simple clamp predictor to yield the 
accurate clamp determination. 

5 

Case 3: Only one of the operands is negative 

When only one of the input operands is negative, their product will be negative. 
Therefore, if an overflow case exists we clamp to the largest (magnitude) negative value, 
10 namely, -2 10 . 

In this case, the simple clamp predictor must count leading ones for the negative 
input, and leading zeros for the positive input. Then, if the sum of the inputs' leading ones 
and leading zeros is less than or equal to 

15 (il-io) + (i2-io) + (io-2) 

= il + i2-io-2 

then the circuit must clamp. 

20 As before, the accurate clamp prediction must use the (io + 1 ) bit of the product, 

i.e., the product must be computed at least to (io + 1) integer bits. This bit is logically 
inverted, then ORed logically with the simple clamp predictor to yield the accurate clamp 
determination. 

Referring now to Fig. 5, another embodiment of the present invention is shown. In 
25 this embodiment, the clamp bit may be stored in a clamp bit register 60 and the result of the 
multiplier operation may be stored in multiplier result register 62. In this embodiment, after 
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one of the result 62 and the clamp value 64 is selected, other logic 68 is introduced to process 
the output 66 as part of a pipelining stage. The pipelining stage enables further processing of 
a partial result if the computation is not completed in a single clock cycle. The clamp 
prediction along with a partial result is then saved for the following clock cycle where 
completion of the clamping prediction will occur in the second clock cycle. 

The initial clamp predictor may be utilized as soon as the two operands are available. 
The final clamp predictor must occur after the result of the multiplier has completed its partial 
computation to the appropriate necessary bit. Therefore, the simple clamp prediction occurs 
at the same time as the multiplier as manipulating operand 1 and operand 2. 

Although two operands are shown, it is contemplated by the present invention that any 
number of operands may be used as inputs to the multiplier operation. In addition, the 
multiplication may occur in several stages with other multiplications coming before or after in 
a similar manner. The cloud of logic represents other multiplications, other additions or other 
logic operations on the result 66 of the multiplexer. 

The present invention has been described in terms of the preferred embodiment, and it 
is recognized that equivalents, alternatives, and modifications, aside from those expressly 
stated, are possible and within the scope of the appending claims. 
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CLAIMS 



1 . A method of detecting overflow in a clamping circuit comprising the steps of: 
inputting a first operand having a first fixed-point format into the clamping 

5 circuit; 

inputting a second operand having a second fixed-point format into the 
clamping circuit; 

determining an overflow output based upon the first and second fixed-point 
format and predicting whether an arithmetic operation of the first operand with the second 
10 operand will yield a result that exceeds the overflow output; and 

performing at least partially the arithmetic operation of the first and second 

operands; 

wherein the determining and predicting step occurs substantially in parallel 
with the performing step. 

15 

2. A method of detecting overflow in a clamping circuit comprising the steps of: 
inputting a first operand having a first fixed-point format into the clamping 

circuit; 

inputting a second operand having a second fixed-point format into the 
20 clamping circuit; 

determining a product overflow output based upon the first and second fixed- 
point format and predicting whether multiplication of the first operand with the second 
operand yields a result that exceeds the product overflow output; and 

performing at least partially the multiplication of the first and second operands; 
25 wherein the determining and predicting step occurs substantially in parallel 

with the performing step. 

3. A method of clamping fixed-point multipliers: 
providing a first operand in a first fixed-point format; 

30 providing a second operand in a second fixed-point format; 

#612372 v2 - MTI-3 1072/patent application (Word) 
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at least partially multiplying the first operand with the second operand to 
produce an operation result; 

determining whether the operation result will exceed a representable value; 

determining a clamping value based on the first fixed-point format of the first 
5 operand and the second fixed-point format of the second operand; and 

substituting the operation result with the clamping value when it is determined 
that the operation result will exceed the representable value; 

wherein the multiplying step and determining whether the operation result will 
exceed the representable value step occur substantially in parallel. 

10 

4. A method of clamping fixed-point multipliers: 
providing a first and second input operand; 
determining a desired number of output bits; 

where any of the first and second input operands are positive, counting a 
1 5 number of leading logical zeros in the positive operand; 

where any of the first and second input operands are negative, counting a 
number of leading logical ones in the negative operands; 

summing the number of leading logical zeros of the positive input operands 
with the number of leading logical ones in the negative input operands; 
20 determining a clamping decision based on the summing step to yield a simple 

clamp predictor representative of the clamping decision; 

computing a product of the first operand and the second operand such that the 
product has the desired number of output bits plus one additional bit; 

logically ORing the simple clamp predictor with a most significant bit of the 

25 product. 

5. The method of claim 4 wherein the computing step and determining the 
clamping decision to yield the simple clamp predictor step occur substantially in parallel. 

30 6. A method of processing multiplier data paths comprising the steps of: 
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performing at least a partial multiplication of a plurality of operands, each 
having a fixed-point format; 

determining whether the at least partial multiplication of the operands produces 
a product that will exceed a pre-determined limit based upon the fixed-point format of each of 
5 the operands; and 

wherein the performance step and the determining step occur substantially in 

parallel. 

7. A method of clamp detection comprising the steps of: 
10 inputting a first and a second operand to both a multiplier and an overflow 

detection circuit; 

multiplying the first and second operands to generate a result not to exceed a 
pre-determined number of bits; 

determining an initial clamping predictor bit based upon the first operand and 
15 the second operand; and 

logically ORing the initial clamping predictor bit and a most significant bit of 
the result to produce a final clamping predictor bit; 

wherein the multiplying and determining steps occur substantially in parallel. 

20 8. The method of claim 7 wherein the first and second operands are in a fixed- 

point format. 

9. The method of claim 7 wherein the most significant bit of the result is logically 
inverted prior to the logically ORing step. 

25 

1 0. The method of claim 8 wherein the step of determining the initial clamping 
predictor bit includes determining a number of logical zeros in each of the operands and 
summing the number of logical zeros to determine whether the sum exceeds a pre-determined 
number to determine the initial clamping predictor bit. 
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1 1 . The method of claim 8 wherein the step of determining the initial clamping 
predictor bit includes determining a number of logical ones in each of the operands and 
summing the number of logical ones to determine whether the sum exceeds a pre-determined 
number. 

5 

12. The method of claim 8 wherein the step of determining the initial clamping 
predictor bit further comprises, when one of the operands is negative and one of the operands 
is positive, determining a number of logical ones for the negative operand and a number of 
logical zeros for the positive operand and summing the number of logical ones and the 

10 number of logical zeros to determine whether the sum exceeds or is equal to a pre-determined 
value for clamping to occur. 

13. A multiplication overflow detection circuit comprising: 
multiplication circuitry for at least partially multiplying a first and a second 

15 operand; and 

overflow detection circuitry receiving the first and second operands that 
detects whether a result of the multiplication of the first and second operands exceed a 
maximum representable positive or negative value; 

wherein the multiplication circuitry and the overflow detection circuitry 
20 operate substantially in parallel. 

14. The circuit of claim 13 wherein the overflow detection circuitry utilizes a 
fixed-point format of the first and second operands to determine whether the result of the 
multiplication exceeds the maximum representable positive or negative value. 

25 

15. An overflow detection circuit comprising: 
a first register for storing a first operand; 

a second register for storing a second operand; 

overflow detection circuitry for detecting an overflow of a multiplication of the 
30 first operand and the second operand and producing a clamp bit; 
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a multiplier for at least partially multiplying the first and second operands and 
generating a result not to exceed a pre-determined number of bits; 

a clamp bit register for storing the clamp bit from the overflow detection 

circuitry; and 

5 a result register connected to the multiplier for storing the result of the 

multiplication of the first and second operands; 

wherein the overflow detection circuitry and the multiplier operate 
substantially in parallel. 

10 16. The overflow detection circuit of claim 1 5 further comprising: 

a multiplexer comprising: 

a clamp value input for receiving a clamp value to be output when clamping 

occurs; 

a clamp bit register input connected to the clamp bit register for receiving the 

15 clamp bit; 

a result register input connected to the result register for receiving the result of 
the multiplication of the first and second operands; and 
an output; 

wherein the multiplexer selects one of the clamp value register input and the 
20 result register input based upon a logical level of the clamp bit register in order to make the 
selected input the output of the multiplexer. 

F 

1 7. The overflow detection circuit of claim 1 5 wherein the clamp bit input is 
logically ORed with a most significant bit of the result stored in the result register. 

25 

18. The overflow detection circuit of claim 15 wherein the registers are flip-flops. 

1 9. The overflow detection circuit of claim 1 5 wherein the first and second 
registers store the first and second operands in a fixed-point format. 
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20. The method of claim 7 further comprising the step of determining whether 
clamping occurs based upon a logical value of the final clamping predictor bit and selecting 
one of a pre-selected clamp value and the result of the multiplying step. 
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ABSTRACT 



A method and apparatus for overflow detection and clamping with parallel 
operand processing for fixed-point multipliers is disclosed. The invention predicts when 

5 a multiplication of a number of operands will exceed a pre-determined number of bits 
based upon the fixed-point format of the operands. The prediction is performed in 
parallel with the multiplication of the operands. The multiplication need not be 
completed in full, but only to the extent to determine whether overflow exists. If an 
overflow detection occurs, clamping is instituted. The parallel operation of the overflow 

1 0 detection and the multiplication provides a faster clamping circuit than would otherwise 
be available from a serial multiplication followed by a clamping analysis. 
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